/*
 * Copyright (c) 2022 Huawei Device Co., Ltd.
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#include "load_d_input_source_callback.h"

#include "dinput_log.h"
#include "distributed_input_source_handler.h"
#include "hisysevent_util.h"

namespace OHOS {
namespace DistributedHardware {
namespace DistributedInput {
LoadDInputSourceCallback::LoadDInputSourceCallback(const std::string &params) : params_(params) {}

void LoadDInputSourceCallback::OnLoadSystemAbilitySuccess(
    int32_t systemAbilityId, const sptr<IRemoteObject> &remoteObject)
{
    DHLOGI("load dinput SA success, systemAbilityId:%d, remoteObject result:%s",
        systemAbilityId, (remoteObject != nullptr) ? "true" : "false");
    if (remoteObject == nullptr) {
        DHLOGE("remoteObject is nullptr");
        return;
    }
    DistributedInputSourceHandler::GetInstance().FinishStartSA(params_, remoteObject);
}

void LoadDInputSourceCallback::OnLoadSystemAbilityFail(int32_t systemAbilityId)
{
    DHLOGE("load dinput SA failed, systemAbilityId:%d", systemAbilityId);
    HisyseventUtil::GetInstance().SysEventWriteFault(DINPUT_INIT_FAIL,
        "dinput source LoadSystemAbility call failed.");
}
} // namespace DistributedInput
} // namespace DistributedHardware
} // namespace OHOS